$(function () {
  let layer = layui.layer
  // 1.1 获取裁剪区域的 DOM 元素
  var $image = $('#image')

  // 1.2 配置选项
  const options = {
    // 纵横比
    aspectRatio: 1,
    // 指定预览区域
    preview: '.img-preview'
  }

  // 1.3 创建裁剪区域
  $image.cropper(options)

  $('#uploadFile').on('click', function () {
    $('#file').click()
  })

  $('#file').on('change', function (e) {
    var filelist = e.target.files
    if (filelist.length === 0) return layer.msg('请选择照片！')
    // 把图片转换为一个url地址 这个URL地址只能在自己电脑上面访问
    $image
      .cropper('destroy') // 销毁旧的裁剪区域
      .attr('src', URL.createObjectURL(filelist[0])) // 重新设置图片路径
      .cropper(options) // 重新初始化裁剪区域
    e.target.value = ''
  })

  $('#upload').on('click', function () {
    // 创建base64格式的字符串图片
    let dataURL = $image
      .cropper('getCroppedCanvas', {
        // 创建一个 Canvas 画布
        width: 100,
        height: 100
      })
      .toDataURL('image/jpeg')
    $.ajax({
      type: 'post',
      url: '/my/update/avatar',
      data: {
        avatar: dataURL
      },
      success: (res) => {
        if (res.status !== 0) {
          return layer.msg('更换头像失败！')
        }
        layer.msg('更换头像成功！')
        window.parent.getUserInfo()
      }
    })
  })
})
